home *** CD-ROM | disk | FTP | other *** search
/ PC World Komputer 2010 April / PCWorld0410.iso / pluginy Firefox / 10900 / 10900.xpi / modules / JSON.js next >
Text File  |  2009-11-25  |  4KB  |  84 lines

  1. /* ***** BEGIN LICENSE BLOCK *****
  2.  * Version: MPL 1.1/GPL 2.0/LGPL 2.1
  3.  *
  4.  * The contents of this file are subject to the Mozilla Public License Version
  5.  * 1.1 (the "License"); you may not use this file except in compliance with
  6.  * the License. You may obtain a copy of the License at
  7.  * http://www.mozilla.org/MPL/
  8.  *
  9.  * Software distributed under the License is distributed on an "AS IS" basis,
  10.  * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
  11.  * for the specific language governing rights and limitations under the
  12.  * License.
  13.  *
  14.  * The Original Code is Personas.
  15.  *
  16.  * The Initial Developer of the Original Code is Mozilla.
  17.  * Portions created by the Initial Developer are Copyright (C) 2008
  18.  * the Initial Developer. All Rights Reserved.
  19.  *
  20.  * Contributor(s):
  21.  *   Myk Melez <myk@mozilla.org>
  22.  *
  23.  * Alternatively, the contents of this file may be used under the terms of
  24.  * either the GNU General Public License Version 2 or later (the "GPL"), or
  25.  * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
  26.  * in which case the provisions of the GPL or the LGPL are applicable instead
  27.  * of those above. If you wish to allow use of your version of this file only
  28.  * under the terms of either the GPL or the LGPL, and not to allow others to
  29.  * use your version of this file under the terms of the MPL, indicate your
  30.  * decision by deleting the provisions above and replace them with the notice
  31.  * and other provisions required by the GPL or the LGPL. If you do not delete
  32.  * the provisions above, a recipient may use your version of this file under
  33.  * the terms of any one of the MPL, the GPL or the LGPL.
  34.  *
  35.  * ***** END LICENSE BLOCK ***** */
  36.  
  37. /**
  38.  * This module wraps the incompatible Gecko 1.9.0 (Firefox 3.0) and Gecko 1.9.1
  39.  * (Firefox 3.5) JSON APIs, presenting the Gecko 1.9.1 API on both versions,
  40.  * for extensions that support multiple versions of Gecko-based applications.
  41.  *
  42.  * Import this module into your extension to parse and stringify JSON in both
  43.  * Firefox 3.0 and 3.5 (and other Gecko-based applications, like Thunderbird)
  44.  * without checking the application's version each time.
  45.  *
  46.  * Note: don't import this into the global namespace!  If you do, you'll hork
  47.  * native application code that expects the Gecko 1.9.0 API.  Instead, import it
  48.  * into your own object like this:
  49.  *
  50.  *   let MyExtension = {
  51.  *     JSON: null,
  52.  *     ...
  53.  *   };
  54.  *   Components.utils.import("chrome://myextension/modules/JSON.js", MyExtension);
  55.  *   // Now MyExtension.JSON is an object implementing the Gecko 1.9.1 JSON API.
  56.  *
  57.  * The Gecko 1.9.1 (Firefox 3.5) JSON API is documented in the article:
  58.  *   https://developer.mozilla.org/En/Using_JSON_in_Firefox
  59.  */
  60.  
  61. let EXPORTED_SYMBOLS = ["JSON"];
  62.  
  63. const Cc = Components.classes;
  64. const Ci = Components.interfaces;
  65. const Cr = Components.results;
  66. const Cu = Components.utils;
  67.  
  68. let appInfo = Cc["@mozilla.org/xre/app-info;1"].getService(Ci.nsIXULAppInfo);
  69.  
  70. // Iceweasel 3.0 has a bug where it reports its platform version as 1.9 instead
  71. // of 1.9.0.n; we work around the bug by checking for 1.9 in addition to 1.9.0.n
  72. // and wrapping the JSON API in both cases.
  73. if (appInfo.platformVersion.indexOf("1.9.0") == 0 ||
  74.     appInfo.platformVersion == "1.9") {
  75.   // Declare JSON with |var| so it'll be defined outside the enclosing
  76.   // conditional block.
  77.   var JSON = {
  78.       JSON: null,
  79.       parse: function(jsonString) { return this.JSON.fromString(jsonString) },
  80.       stringify: function(jsObject) { return this.JSON.toString(jsObject) }
  81.   }
  82.   Cu.import("resource://gre/modules/JSON.jsm", JSON);
  83. }
  84.